草庐IT

python - 用python解析outlook .msg文件

全部标签

ruby-on-rails - 您将如何解析 Ruby 中的 url 以获取主域?

我希望能够使用Ruby解析任何URL以获取没有www的域的主要部分(只是example.com) 最佳答案 请注意没有算法方法可以找到可以为特定顶级域注册域的最高级别(每个注册管理机构的政策不同),唯一的方法是创建所有顶级域的列表以及域可以注册的级别。这就是为什么PublicSuffixList存在。我是PublicSuffix的作者,一个将域分解为不同部分的Ruby库。举个例子require'uri/http'uri=URI.parse("http://toolbar.google.com")domain=PublicSuffix

ruby - 将 CSV 文件转换为哈希数组

我有一个csv文件,一些曲棍球统计数据,例如:09.09.2008,1,HCVitkoviceSteel,BKMladaBoleslav,1:0(PP)09.09.2008,1,HCLasselsbergerPlzen,RIOKNAZLIN,6:209.09.2008,1,HCLitvinov,HCSpartaPraha,3:5我想将它们保存在一个哈希数组中。我没有任何header,我想为每个值添加键,例如"time"=>"09.09.2008"等等。每行都应该像arr[i]一样可访问,每个值都应该像arr[i]["time"]一样可访问。我更喜欢CSV类而不是FasterCSV或sp

ruby-on-rails - 没有要加载的文件 -- readline

我收到以下错误:$script/consoleLoadingdevelopmentenvironment(Rails2.2.2)/opt/ruby-enterprise-1.8.6-20080709/lib/ruby/1.8/irb/completion.rb:10:in`require':nosuchfiletoload--readline(LoadError)我在哪里可以得到这个文件,它应该放在什么目录中?谢谢! 最佳答案 readline模块通常是Ruby包本身的一部分。您是否手动构建了Ruby安装?如果是这样,您需要确保安装

ruby - 在文件中搜索字符串的最佳方法是什么?

标题本身就说明了一切。我只想知道它是否存在,而不是它在哪里。是否有一个衬垫可以实现这一目标? 最佳答案 File.open(filename).grep(/string/)这会将整个文件载入内存(slurps文件)。你应该避免文件slurpingwhendealingwithlargefiles.这意味着一次加载一行,而不是整个文件。File.foreach(filename).grep(/string/)最好自己清理,而不是让垃圾收集器在某个时候处理它。如果您的程序是长期存在的,而不仅仅是一些快速脚本,那么这一点就更为重要。使用代

ruby - 读取文件时如何避免被 UTF-8 BOM 绊倒

我正在使用最近添加了UnicodeBOMheader(U+FEFF)的数据提要,现在我的rake任务被它搞砸了。我可以使用file.gets[3..-1]跳过前3个字节,但是是否有更优雅的方式来读取Ruby中的文件,它可以正确处理这个问题,无论BOM是有没有? 最佳答案 在ruby​​1.9.2中,您可以使用模式r:bom|utf-8text_without_bom=nil#definethevariableoutsidetheblocktokeepthedataFile.open('file.txt',"r:bom|utf-8")

ruby - 如何让 Ruby 像在不同时区一样解析时间?

我正在解析这样的东西:11/23/1023:29:57它没有与之关联的时区,但我知道它在UTC时区(但我不是)。如何让Ruby将其解析为UTC时区? 最佳答案 您可以在解析之前将UTC时区名称附加到字符串:require'time's="11/23/1023:29:57"Time.parse(s)#=>TueNov2323:29:57-08002010s+="UTC"Time.parse(s)#=>TueNov2323:29:57UTC2010 关于ruby-如何让Ruby像在不同时区一

ruby - 如何将 stderr 和 stdout 重定向到 Ruby 脚本文件?

如何将stderr和stdout重定向到Ruby脚本文件? 最佳答案 在Ruby脚本中,您可以使用IO#reopen重定向stdout和stderr方法。#a.rb$stdout.reopen("out.txt","w")$stderr.reopen("err.txt","w")puts'normaloutput'warn'somethingtostderr'$lsa.rb$rubya.rb$lsa.rberr.txtout.txt$caterr.txtsomethingtostderr$catout.txtnormaloutput

ruby-on-rails - Ruby/Rails CSV 解析,UTF-8 中的无效字节序列

我正在尝试解析从Excel电子表格生成的CSV文件。这是我的代码require'csv'file=File.open("input_file")csv=CSV.parse(file)但是我得到这个错误ArgumentError:invalidbytesequenceinUTF-8我认为错误是因为Excel将文件编码为ISO8859-1(Latin-1)而不是UTF-8谁能帮我解决这个问题提前致谢。 最佳答案 您需要告诉Ruby该文件在ISO-8859-1中。将您的文件打开行更改为:file=File.open("input_file

ruby-on-rails - 使用回形针通过 Activeadmin Rails 上传文件

我使用Activeadmin作为我的Rails应用程序后端。我想上传文件。我怎样才能完成这个功能? 最佳答案 我找到了一种将Paperclip与ActiveAdmin结合使用的方法。我在模型“事件”中添加了这段代码:has_attached_file:map,:styles=>{:medium=>"238x238>",:thumb=>"100x100>"}我为我的管理模型做了这个:ActiveAdmin.registerEventdoform:html=>{:enctype=>"multipart/form-data"}do|f|f

ruby - 使用 Ruby 解析 XML

我是使用XML的新手,但刚好有需要。我得到了一种常用的(对我而言)XML格式。标签内有冒号。1234TheName这是一个大文件,其中包含的内容远不止于此,但我希望有人会熟悉这种格式。有谁知道处理此类XML文档的方法吗?我宁愿不只是编写一种解析文本的蛮力方法,但我似乎无法使用REXML或Hpricot取得任何进展,我怀疑这是由于这些不寻常的标签。我的ruby代码:require'hpricot'xml=File.open("myfile.xml")doc=Hpricot::XML(xml)(doc/:things).eachdo|thg|['Id','Name'].eachdo|el|